草庐IT

java - 奇怪的 .bat 文件行为

全部标签

ruby-on-rails - Rubyzip:将 zip 文件直接导出到 S3 而无需将 tmpfile 写入磁盘?

我有这段代码,它将一个zip文件写入磁盘,读回,上传到s3,然后删除文件:compressed_file=some_temp_pathZip::ZipOutputStream.open(compressed_file)do|zos|some_file_list.eachdo|file|zos.put_next_entry(file.some_title)zos.printIO.read(file.path)endend#Writezipfiles3=Aws::S3.new(S3_KEY,S3_SECRET)bucket=Aws::S3::Bucket.create(s3,S3_BUCK

ruby - 奇怪的 Ruby 类初始化逻辑?

我在我的应用程序中集成的一些开源代码有一些类包含实现该效果的代码:classSomeClass据我所知,self.new和initialize都做同样的事情——后者是“构建期间”,前者是“构建后”,在我看来,这是一种可怕的模式-为什么将对象初始化分成两部分,其中一个显然是“错误的想法(tm)”? 最佳答案 理想情况下,我想看看super().tap{|o|里面有什么block,因为虽然这看起来像是不好的做法,但也许在initialize之前或之后需要一些交互被称为。如果没有上下文,您可能只是在看一些有效但在Ruby中不被认为是好的做

ruby - 我怎样才能可靠地发现 Ruby 可执行文件的完整路径?

我想写一个脚本,打包成一个gem,它将修改它的参数,然后用修改后的参数exec一个新的ruby进程。换句话说,类似于修改其参数然后执行exec$SHELL$*的shell脚本。为此,我需要一种可靠的方法来发现正在执行当前脚本的ruby​​可执行文件的路径。我还需要获取传递给当前进程的完整参数——Ruby参数和脚本参数。 最佳答案 Rake源代码是这样的:RUBY=File.join(Config::CONFIG['bindir'],Config::CONFIG['ruby_install_name']).sub(/.*\s.*/m,

ruby - 在 Ruby 中解析二进制文件

我需要能够使用Ruby解析二进制文件。此文件包含通过header找到的数据block,header包括文件偏移量和每个block的长度。如何正确取出数据?到目前为止,我一直无法根据我读出的偏移量在文件中四处寻找,因为它们以我不知道如何转换为IO#seek理解的格式的字符串形式出现。有什么帮助吗?将偏移量和长度转换为可用值(如整数或其他值)的通用方法会有所帮助。 最佳答案 你想要String#unpack. 关于ruby-在Ruby中解析二进制文件,我们在StackOverflow上找到一

ruby - 与 block 一起使用时,ruby Hash#merge 的行为是什么

它似乎没有被记录很多:hsh.merge(other_hash){|key,oldval,newval|block}→a_hashhttp://ruby-doc.org/core/classes/Hash.html#M002880 最佳答案 正如预期的那样,生成的散列将包含一个block返回的值,该block针对存在于两个正在合并的散列中的每个键:>>h1={:a=>3,:b=>5,:c=>6}=>{:a=>3,:b=>5,:c=>6}>>h2={:a=>4,:b=>7,:d=>8}=>{:a=>4,:b=>7,:d=>8}>>h1

ruby - 为 Heroku 静态编译 pdftk。需要将 PDF 拆分为单页文件

所以我们使用heroku来托管我们的rails应用程序。我们搬到了雪松堆。此堆栈未安装pdftk库。我联系了支持人员,被告知为amd64ubuntu静态编译它并将其包含在我的应用程序中。事实证明,这比我想象的要难。最初我下载了ubuntu的包(http://packages.ubuntu.com/natty/pdftk),将其解压缩,并包含二进制文件和共享库。我收到奇怪的错误,例如:UnhandledJavaException:java.lang.NullPointerExceptionatcom.lowagie.text.pdf.PdfCopy.copyIndirect(pdftk)

ruby - 为什么我不能在 ruby​​ 的父目录中要求一个文件?

请注意,我没有使用Rails。我的目录结构如下:foo/bar/base_classes/base_classes.rb基础类.rb:Dir.glob(File.expand_path(File.join("base_classes/config/constants","*.rb"))){|file|requirefile}Dir.glob(File.expand_path(File.join("base_classes","*.rb"))){|file|requirefile}当我在这个根目录下>>require'base_classes'#=>true>>Card.load![st

ruby - 使用 ruby​​ 流式传输和解压缩大型 csv 文件

我遇到问题,我需要下载、解压缩,然后逐行处理一个非常大的CSV文件。我认为让您了解文件有多大很有用:big_file.zip~700mbbig_file.csv~23gb这是我希望发生的一些事情:解压缩前不必下载整个文件在解析csv行之前不必解压缩整个文件在执行所有这些操作时不要占用太多内存/磁盘我不知道这是否可能。这是我的想法:require'open-uri'require'rubyzip'require'csv'open('http://foo.bar/big_file.zip')do|zipped|Zip::InputStream.open(zipped)do|unzipped

ruby-on-rails - 没有要加载的文件 -- bundler/setup

我正在尝试让Rails在Rackspace服务器上运行,不幸的是,它们不支持Rails。我在Ubuntu上使用Apache和Passenger(没有RVM)。当我访问服务器时,出现以下错误:nosuchfiletoload--bundler/setup回溯如下:/usr/lib/ruby/1.8/rubygems/custom_require.rb31ingem_original_require'/usr/lib/ruby/1.8/rubygems/custom_require.rb31inrequire'/rails/gradebook-attendance/config/boot.

ruby - 如何在 Ruby 中将数据 URI 转换为文件

如何转换来自FileReaderAPI结果的数据URI转换成可以保存在Ruby文件系统中的图像文件?我目前正在尝试做的是使用base64解码将如下所示的data_uri字符串:data:image/jpeg;base64,/9j/4AAQSkZJRgABAQEAYABgA...转换为base64编码字符串因为根据这个stackoverflowanswer我需要将所有空格实例替换为+。答案是在PHP中,但我目前正在研究Ruby和Sinatra,所以我不确定它是否仍然适用,但是当使用等效代码时:src=data_uri.gsub!'','+'src=Base64.decode64(src)